<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <input type="checkbox" class="checkAll">
    <br>
    <input type="checkbox" class="checkOne">
    <input type="checkbox" class="checkOne">
    <input type="checkbox" class="checkOne">

    <script>

        var oAll = document.querySelector('.checkAll') ;
        var oOnes = document.querySelectorAll('.checkOne') ;

        oAll.onclick = function() {
            // 给所有的单选改状态
            for(var i = 0 ; i < oOnes.length ; i++) {
                oOnes[i].checked = this.checked ;
            }
        }


        // 反选

        // 循环绑定事件
        // for(var i = 0 ; i < oOnes.length ; i++) {
        //     // 绑定事件是同步的
        //     console.log(i) ;   // 0 1 2
        //     oOnes[i].onclick = function() {
        //         // 在函数内部是异步的
        //         var flag = true ;
        //         for(var j = 0 ; j < oOnes.length ; j++) {
        //             if(!oOnes[j].checked) {
        //                 flag = false ;
        //                 break ;
        //             }
        //         }
        //         oAll.checked = flag ;
        //     }
        // }





         // 循环绑定事件
         for(var i = 0 ; i < oOnes.length ; i++) {
            // 绑定事件是同步的
            console.log(i) ;   // 0 1 2
            oOnes[i].onclick = function() {
                // 在函数内部是异步的
                for(var j = 0 ; j < oOnes.length ; j++) {
                    // 如果有一个没有选中就提前结束循环
                    if(!oOnes[j].checked) {
                        break ;
                    }
                }
                // 如果提前结束循环，说明至少有一个没有选中 ， 那么全选就不选中
                // 如果循环正常结束，j === length  全选就选中
                // oAll.checked = j === oOnes.length ? true : false ;
                oAll.checked = j === oOnes.length ;
            }
        }

    </script>
    
</body>
</html>